import store from '@/store'
// import axios from 'axios'
import { Toast } from 'vant'

// // 创建 axios 实例，将来对创建出来的实例，进行自定义配置
// // 好处：不会污染原始的 axios 实例
// const instance = axios.create({
//   baseURL: 'http://cba.itlike.com/public/index.php?s=/api/',
//   timeout: 5000
// })

// // 自定义配置 - 请求/响应 拦截器
// // 添加请求拦截器
// instance.interceptors.request.use(function (config) {
//   // 在发送请求之前做些什么
//   // 开启loading，禁止背景点击 (节流处理，防止多次无效触发)
//   Toast.loading({
//     message: '加载中...',
//     forbidClick: true, // 禁止背景点击
//     loadingType: 'spinner', // 配置loading图标
//     duration: 0 // 不会自动消失
//   })

//   // 只要有token，就在请求时携带，便于请求需要授权的接口
//   const token = store.getters.token
//   if (token) {
//     config.headers['Access-Token'] = token
//     config.headers.platform = 'H5'
//   }

//   return config
// }, function (error) {
//   // 对请求错误做些什么
//   return Promise.reject(error)
// })

// // 添加响应拦截器
// instance.interceptors.response.use(function (response) {
//   // 2xx 范围内的状态码都会触发该函数。
//   // 对响应数据做点什么 (默认axios会多包装一层data，需要响应拦截器中处理一下)
//   const res = response.data
//   if (res.status !== 200) {
//     // 给错误提示, Toast 默认是单例模式，后面的 Toast调用了，会将前一个 Toast 效果覆盖
//     // 同时只能存在一个 Toast
//     Toast(res.message)
//     // 抛出一个错误的promise
//     return Promise.reject(res.message)
//   } else {
//     // 正确情况，直接走业务核心逻辑，清除loading效果
//     Toast.clear()
//   }
//   return res
// }, function (error) {
//   // 超出 2xx 范围的状态码都会触发该函数。
//   // 对响应错误做点什么
//   return Promise.reject(error)
// })

// // 导出配置好的实例
// export default instance



// @/utils/request.js
import axios from 'axios';

// 创建 axios 实例
const instance = axios.create({
	baseURL: 'http://smart-shop.itheima.net/index.php?s=/api', // 接口地址
	timeout: 5000, // 超时设置
	headers: {} // 默认请求头--->尼玛这里居然是空的
});

// 配置请求和响应拦截器
instance.interceptors.request.use(function(config) {
	// 在请求之前可以做一些操作
	//添加加载中的动画，防止多次点击
	Toast.loading({
		message: '加载中',
		forbidClick: true,
		loadingType: 'spinner',

	})
	//每次请求都要验证拦截headers
	const token = store.getters.token
	if (token) {
		config.headers['Access-Token'] = token
		config.headers.platform = 'H5'
	}

	return config;
}, function(error) {
	// 请求错误时做一些处理
	return Promise.reject(error);
});

instance.interceptors.response.use(function(response) {
	// 响应成功时做一些处理
	return response.data; // 返回数据（可以是 response.data，依据你的后端接口返回的数据结构）
}, function(error) {
	// 响应错误时做一些处理
	return Promise.reject(error);
});

// 导出配置好的 axios 实例
export default instance;